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YEROTH-—ERP-3.0 Software—System Architecture 


PR. XAVIER NOUMBISSI NOUNDOU 


This document describes the thick—client software-system architecture of YEROTH—-ERP- 
3.0. This document also explains the reasons for which we chose to design and implement 
YEROTH-ERP-—3.0 as a thick—client software—system, as opposed to currently more popular 
web-—browser—based software—system. 


This document further demonstrates the superiority, in terms of simplicity, speed, mainte- 
nance, and low costs of development of thick—client software—system architectures over web— 
browser—based software—system architectures ! 
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Chapter 1 


Introduction 


This introduction motivates why | created YEROTH—-ERP-3.0, and why it uses 
the best software programming language of its time ! 


1.1 Motivation 


YEROTH-ERP-3.0 is an Enterprise Resource Planing (ERP) software—system that aims ‘effective- 
ness’ and ‘simplicity’, compared to other high ranked ERP software—systems (e.g.: ‘Sage Gescom i7’, 
‘SAP Business One’, etc.). 


We chose to design and implement YEROTH—ERP-3.0 as a thick—client software-system because 
of the following reasons: 


1. The implementation language C++ offers much flexibility: 
1. MULTIPLE INHERITANCE: 


It allows developers to abstract as much as possible business code upwards, away from 
downwards implementation classes. For instance, in YEROTH—ERP-3.0, GUI—Qt—windows 
inherits for instance search filtering feature, and print capability from 2 different classes. 


Print capability couldn't be inherited from the same class where search filtering is abstracted 
and partially implemented (interface in Java for instance doesn’t allow any method body 
code), because it works in its pure abstract class (C++ class with at least 1 empty method 
body), together with feature database column filtering for viewing and printing. 


The drawback of the multiple inheritance in C++ Is: it sometimes can be very difficult to build 
itusing “gcc (g++) [GCC]"! 


2. MACROS: 
They enable developers to create TEXT TEMPLATE in their code. 


For instance, | use macros in some parts of my code to reduce execution time and stack acti- 
vation records size for method or function calls in YEROTH—-ERP-—3.0 ! 


2. The availability of ?WHAT YOU SEE IS WHAT YOU GET’ (WYSIWYG) tools for fast and useful 
user interface design (e.g.: Qt designer [Com2O], miniStudio (vxWorks) [WEI2O], etc.) 


3. The low number of logical software—system architecture layer (i.e.: 2.) involved with the use 
of a thick—client software—system architecture, as opposed to a web—browser—based software— 
system (i.e.: 4, client user interface, presentation layer, business logic, and data (DBMS) ). 
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Chapter 2 


Thick—Client VS. Web-—Browser—bDased 
Software—System Architecture 


This comparison chapter tabular evaluates why thick—client are BETTER THAN 
web-—browser—based software—system architectures | 


2.1 Thick—client: 2 layers logical software architecture 


"rs 


Thick et Database 





Figure 2.1: 2-layers logical architecture of thick—client software-system (Image copied from 
[sec20]). 


Figure 2.1 illustrates an example of a thick—client software—system with a 2—layers logical architec- 
ture. 


2.2 Web-—browser based: at least 4 layers logical software ar- 
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Figure 2.2: 4-layers logical architecture of web—browser—based software—system (Image copied 
from [KMO6]). 


Figure 2.2 illustrates an example of a web—browser—based software—system with a 3-Layers logical 
architecture. 
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Table 2.1 compares thick—client software—systems against web—browser—based software—systems. 
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2.3 Tabular Comparison Between Thick-Client And Web Browser— 
based Architecture 


Thick—client application Vv Web-browser—based application 
business code user interface application server 
co—related software—systems 1 (DBMS) at least 3 (DBMS, web / application server) 
number of logical layers 2 (client and data) 4 (client, presentation, logic, and data) 
rapid prototyping (WYSIWYG tools) yes very limited 
software security vulnerability Low (1 programming language) VERY high (several programming languages) 
user interface all computers (GUI with BUS/NESS CODE) all computers (web—browser) 


Table 2.1: Thick—client application VS Web—browser—based application. 


Table 2.1 illustrates the advantages of thick—client software—system architecture over web—browser— 
based software—system architecture | 


The common argument for web—browser—based software—system architecture is you update the 
business code just at 1 place: the application server ! 


| argue that thick—client architecture IS JUST AS WELL BEST UPDATED AT 1 PLACE: the user’s 
computer. 


FOR INSTANCE, UPDATE OR UPGRADE OF ENTERPRISE SOFTWARE-SYSTEM WEB—-BROWSER-— 
BASED REQUIRES ALLMOST AT LEAST 1-—24-—HOURS SHUTDOWN OF ALL INVOLVED WEB 
(apache tomcat, etc.) APPLICATIONS SERVERS. 


The issue of automatic software upgrade in a computer network is best solved by the ‘apt upgrade 
software—system of Debian-Linux’, as an example |! 
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Chapter 3 


The Thick—Client Software—System 
Architecture of YEROTH—ERP-—3.0 


This chapter explains why YEROTH—ERP-3.0 is modular in its uses, and fits any 
industrial setting ! 


Thick—client application v Web-browser—based application 
business code user interface application server 
co—related software—systems 1 (DBMS) at least 3 (DBMS, web / application server) 
number of logical layers 2 (client and data) 4 (client, presentation, logic, and data) 
rapid prototyping (WYSIWYG tools) yes very limited 
software security vulnerability Low (1 programming language) high (several programming languages) 
user interface all computers (GUI with BUS/NESS CODE) all computers (web—browser) 


Table 3.1: Thick—client application VS Web—browser—based application. 


3.1 Business and user interface code deployment 


Table 3.1 depicts the issue of business and user interface code deployment on all computers partic- 
ipating in the functioning of YEROTH—ERP-—3.0, as a software—system for a user. 


We tackle the problem of automatic deployment of business and user interface code on all user 
computers by using the ‘apt upgrade’ software—-system on ‘Debian-Linux’. 


3.2 Databases 


DBMS MySQL is used for storing and managing huge data accross globe. 


3.3 NUMBER OF LOGICAL SOFTWARE-SYSTEM LAYERS: E.G. 
Sample technical configurations 


This section illustrates 2 different possible computer network configurations that could prevail in 
industry. 
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3.3.1 Sample 2—computers store 
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Figure 3.1: Sample 2—computers store. 
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3.3.2 Sample decentralized multi sites supermarket 
YEROTH, 4 
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Figure 3.2: Sample decentralized multi sites supermarket. 
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3.4 Software Security Vulnerability in YEROTH—-ERP-3.0 


| perform security vulnerability detection for open source software YEROTH—-ERP-3.0 by using 
memory leak detection tool ‘valgrind’ (ct. []). 
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Chapter 4 


Conclusion 


This conclusion explains why YEROTH—-ERP-3.0 uses the BEST SOFTWARE 
TECHNOLOGY IN TERMS OF SOFTWARE-SYSTEM ARCHITECTURE ! 


YEROTH—ERP-—3.0 Odoo 
libraries & programs lxqt-sudo, etc. python-lxml, etc. 
user interface code TOOLS WYSIWYG QT—DESIGNER (CUSTOM BUILD) FRAMEWORKS 
business code Cre Python, JavaScript, XML 
DBMS MySQL PostgresQL 
web-—server Werkzeug 


Table 4.1: YEROTH—ERP-3.0 VS. Qdoo. 


YEROTH-ERP-—3.0 has a thick—client software—-system architecture because we found thick—client 
software—system architectures simpler than web—browser—based software—system architectures. 


Thick—client software—system architectures is simpler because it requires less Layers in its Logical (or 
physical) software—-system architecture, and is easier to develop and maintain as a software—system 
application. 


Table 2.1 illustrates a thick—client software-system is SUPERIOR IN TERMS OF TOOLS FOR 
MAINTENANCE AND DEVELOPMENT than a web—browser—based software—system ! 
A web-browser—based software—system architecture has more drawbacks as follows: 


1. it requires at least 2 other software-systems, apart from the ones normally required by devel- 
oped software-system itself, for instance libraries (e.g.: Log4j), to fully operate (e.g.: web 
server, application server, etc.). 


Table 4.1 depicts this situation in the light of the open source ERP software—system Qdoo. 


Accordingly, a thick—client software—system doesn't require any running and managing infrastruc- 
ture such as for example an application server ! 


2. A web-—browser—based software—system requires at least 4 layers in its logical system architec- 
ture (e.g.: client, presentation, logic, and data layers). 


Accordingly, a thick—client software—system only requires at least 2 layers ! 


3. A web-—browser—based software—system potentially entails more software security vulnerabili- 
ties because its implementation requires the use of at least 2 different programming languages, 
and frameworks in combination. 


Accordingly, a thick—client software-system needs only the use of 1 homogeneous software 
programming language ! 
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YEROTH-—ERP-3.0 Software— 
System Product Sheet 


Yeroth-erp-3.0 - user window 


YEROTH-ERP-—3.0 is an ERP software—system with 6 user 
roles, and types: 

« Administrator » 

« Business manager » 

« Cashier » 

« Seller » 

« Stock manager » 

« Storekeeper ». 


SN See ea 


database ip address: "localhost" - database table: "yeroth_erp_3" - database options: "" 





YEROTH—-ERP-3.0 features: 

alerts over stock quantity, and, time period 
business dashboard 

customer relationship management (CRM) 
sale management (e.g. point-of-sale) 
stock management (e.g. check in) 

user, and role administration. 


Business manager's main window 


Yeroth-erp-3.0 - point of sale - FIFO [ pdf receipt size: ‘small’ ] 


ee hr 


YEROTH—-ERP-—3.0 ts: 

1. easier, and, intuitiver, in its use 

2. lighter, and, faster, in memory usage 
3. multi sites (enabled). 


YEROTH-—ERP-3.0's runtime memory usage test is realized 
using software analysis tool valgrind. 


database ip address: "localhost" - database table: "yeroth_erp_3" - database options: "" 





Cashier's main window 











OPERATIONS 
Point—of—Sale Hardware Database Management Operating Systems 
Vv Barcode scanner tll J Debian-Linux 
Jv Thermal printer, etc. J MySQL 
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Advantages of YEROTH-ERP- 
3.0 Compared to other top ERP 
Software—Systems 


Yeroth-erp-3.0 - stock listing - FEFO 


YEROTH-ERP-—3.0 is a very easy to use ERP (Enterprise Re- 
source Planing) software—-system because of its characteris- 
tics: 

separate views for each user role 

complete and fundamental training in 5 days 

easy to use graphical user interface (GUI) 

no college or university training needed 

no formal business training needed 

no financial accounting training needed 





~~ Oe ee IY 


no internet connection needed. 
Stock listing window 


Table 1 pictures the ‘effectiveness’ and ‘simplicity’ of YEROTH—ERP-—3.0, compared to other top ERP 
software—systems “Sage Gescom i7”, and “SAP Business One”. 


YEROTH-ERP-3.0 Sage Gescomi7 SAP Business One 


separate views per user role YES NO = 
complete training (or solution) 5 days at least 2months at least 3 months 
difficulty in navigation very easy difficult very difficult 
usage language in software easy everyday English simple technical 
financial accounting knowledge no no useful 
advanced marketing knowledge no useful useful 
internet connection optional mandatory optional 


Table 1: Comparison between YEROTH-ERP-3.0 and 2 top tier—1 full featured ERP software— 








systems 

OPERATIONS 
Point—of—Sale Hardware Database Management Operating Systems 
Vv Barcode scanner eyetes J Debian—Linux 
Jv Thermal printer, etc. ¥ MySQL 
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YEROTH—-ERP-3.0 Point-—Of—Sale 
Recommended Hardware 


1 Barcode Scanner 


We recommend, but not exclusively, the use of barcode 
scanner: “ Xfox FJ-5 USB Plug and Play Automatic 
Barcode Scanner ” (approx. 17 €). 


2 Thermal Printer 


We recommend, but not exclusively, the use of ther- 
mal printer: “ Epson TM-T2Oii Point of Sale Ther- 
mal Printer “ (approx. 100 €). 


3 Cash Drawer 


We recommend, but not exclusively, the use of cash 
drawer: “ HP QT457AT “ (approx. 90 €). 


4 Touch Screen Monitor 


We recommend, but not exclusively, the use of touch 
screen monitor: “ ASUS 15.6" LCD Monitor (VT168H) ” 
(approx. 155 €). 


5 Computer 
We recommend, but not exclusively, the use 


of desktop computer: “Lenovo Thinkcen- 
tre M720 Small Form Factor (SFF) “ (approx. 450 €). 
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Information Brochure of the 


ERP software—-system 
YEROTH-ERP-3.0 


PR. XAVIER NOUMBISSI NOUNDOU 


Tasks « Business manager » « Seller » « Stock manager» «Storekeeper» « Cashier » 
insert stock (or service) ye JV (SERVICE) V (STOCK) 

delete stock 

view stock 

modify stock 

transfer stock 

modify stock 

management strategy 

(e.g.: « FIFO », etc.) 

point—of-—sale 

view stock transfers 

purchase management 

supplier management 

customer relationship management (CRM) 
business dashboard 

sale return 

view sales information 


J 


NEN 


J (NO PERMANENT) V (NO PERMANENT) 


7 v4 
v o 
J (PARTIAL) 


IASI SIS) SLATES 
AIT S 


JV (SELF) 


Table 1: YEROTH—ERP-—3.0 functions—tasks, and associated users—roles. 


1 Developer Biography 1. source code: 
http: //github.com/xnoumbissinoundou/ 
yeroth.rd.saint 

2. full text (published on July 1%, 2015): http: // 
archive.org/details/saint_201507. 


2. ‘YEROTH-ERP-3.0"': 


1. source code: 
http://github.com/xnoumbissinoundou/ 
yeroth-erp-3.0 

2. full text (ongoing publication): http://archive. 
org/details/yeroth-erp-3-0-info-english. 





i 


Figure 1: Portrait of PR. XAVIER. 


2 Introduction 


YEROTH-ERP-3.0 is an Enterprise Resource Planing 
PR. XAVIER NOUMBISSI NOUNDOU is a CHRISTIAN (ERP) software—system. 
BY FAITH, Cameroonian, born on September 16 1983 in 


DOUALA (LITTORAL region, CAMEROON). rials of YEROTH-ERP-3.0 could have the following 
roles: 


Xavier has a “Diplom—I/nformatiker (Dipl.—Inf.)” qualification 


from the University of Bremen, Bremen, Bremen, GER- 1. « Administrator » 


MANY (May 25, 2007). 2. « Business manager » 
a 2 . 3. « Cashier » 

Xavier is a PH.D. in Software Engineering (software con- 

struction, and testing) since November 18, 2020 because of 4. « Seller » 

his academic research, and professional engineering contri- 5. « Stock manager » 

butions as follows: 6. « Storekeeper », 


1. ‘Context-Sensitive Staged Static Taint Analysis For C YEROTH-ERP-3.0 allows for business management tasks 
using LLVM' listed in Table 1, depending on user role. 
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3 Advantages of YEROTH—-ERP- 


3.0 


1. YEROTH—ERP-—3.0 is 100% stable 


2. YEROTH-ERP-—3.0 has an alert system with two types 
of alerts: alerts based on stock—quantity, and time— 
period alerts 


3. users have the choice between small size receipts, and, 
bigger size receipts ("A4”") 


4. YEROTH—ERP-3.0 runs on the Linux operating system, 
because Linux is stable, performant, and less vulnera- 
ble to security breaches in comparison to other oper- 
ating systems (‘Windows 10’) 


5. YEROTH-ERP-3.0 has an user interface “Sales” to 
view sale information (Figure 2), and thus enables 
users to make managerial decisions 


6. YEROTH-ERP-3.0 has an interface “Business dash- 
board” that generates financial accounting reports, 
from sale and payment information, to help managers 
to make “business decisions”. 


Yeroth-erp-3.0 - sales - *x 


Functions Tools Help 


e & ww +8 ow @ & be Main menu 


Sale details Sale return 


aty | Total sale 


2 Bera vaieriy) TENSIONORME CPR BT 24 1.00 
02.12.2020 MASQUE CHIR B/50 ymele) 
02.12.2020 | CA C1000 CPR EFFV ORANGE B/10 


Product name 


pe celenele) 
pRelelexele) 
1,775.00 


4,595.00 


02.12.2020 AZITRINE 500MG CPR B/3 1.00 

02.12.2020 | ARTESIANE 40MG SUPPOGEL B/6 1.00 

02.12.2020 |ALCOOL ETHYLIQUE 90° SOLF/125| 1.00 

O 18.12.2020 ACFOL 5MG CPR B/252 a 
wows 


Begin 02/12/2020 
End 19/12/2020 
Sale type 
Profit >= 


2,865.00 


pm leleRele) 


1/1 


Sale receipt ref. 


Sold quantity 
Tax (€) 

Total discount 
Total sale 


0.00 € 
0.00 € 
19,590.00 € 





reset filter filter 





Figure 2: Sale—information window. 


4 Alert System 


Users with roles « Administrator » or « Business manager » 
are the ones able to create alerts. 


YEROTH—ERP-—3.0 allows its users to create two types of 
alerts: 


1. alerts over stocks—quantities 


2. alerts over time intervals (this helps for perissable ar- 
ticles and for sales discounts over a period of time). 


4.1 Alerts over Stock—Quantity 


An alert aver a stock—quantity is a message that is sent to 
a pre-determined user whenever “pre-determined” stock— 
quantity (X) of a specific article-stock is reached. 


For instance, Xavier (« Business manager ») could create 
an alert for stock “mango” that will be trigerred whenever 
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stock “mango” quantity reaches 100; An alert—message is 
sent to user John (« Storekeeper »). 


4.2 Alerts over Time—Period 


A time-period is defined by a starting—date and an ending— 
date (dates are from the “gregorian” calendar). 


An alert aver a time-period (T) is a message that is gen- 
erated, sent to a pre-determined user, and kept within 
YEROTH—ERP-3.0 from T's starting—date up to I's ending— 
date. 


For example, an alert with a message has to be sent to Paul 
(« Cashier ») when the date of May 05" is reached. The alert 
message specifies that a rebate of 20% has to be applied on 
every sale of yoghourt ‘trésbon’ during a time interval of 2 
weeks. 


5 Database 
tem 


Management Sys- 


YEROTH—ERP-3.0 uses ?MariaDB’ as the standard DBMS. 
?MariaDB’ is very stable, very performant, and free— 
software. 


6 Conclusion 


Yeroth-erp-3.0 - point of sale - FIFO [ pdf receipt size: ‘small’ ] - *x 
Functions Tools Help 


2 
&: | "™_ Mainmenu View stocks 


Reference Product name Category Qty Stockqty Unit price Tax | Total ATC 


Cashier Item count 
Subtotal 
Tax (7.25 %) 


Total ATC 


Xavier Yeroth YEROTH 


Printer 0.00 € 


printreceipt v 


Customer name al 


Change due 


0.00 € 
0.00 € 


cancel check out 


database ip address: "localhost" - database table: "yeroth_erp_3" - database options: "" 


Figure 3: Point-of—sale window. 


Figure 3 illustrates the window for selling articles. 
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Figure 4: Administrative window for business manager. 
Yeroth-erp-3.0 ~ Opérations ~ fenétre de l'administrateur - *x 


Actions Outils Aide Figure 4 illustrates the administrative window for business 
a Menu principal Managers. 


Lister Modifier Supprimer 


Connecter une localisation Entreprise Importer Maintenance Opérations Paramétresdel'application SYS 


opérations objets 


créer une alerte 


database ip address: "localhost" - database table: "yeroth_erp_3" - database options: "" 
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